相当于 PyQuery 或 Nokogiri 的 PHP?
全部标签 Nokogiri很棒。我可以做#css('.bla')这样的事情,它会返回第一个匹配的元素。现在我们需要对Ruby源代码进行一些解析-查找类中的所有方法等。我们正在使用ruby_parsergem,但它所做的只是梳理你的源代码并吐出S表达式。对于这些S表达式,是否有类似Nokogiri的东西可以执行诸如“为找到的名为‘foo’的第一个方法返回S表达式”之类的事情? 最佳答案 我唯一能想到的是AdamSanderson'sSExpPathlibrary. 关于ruby-是否有类似于Noko
我使用Rails5来使用Rails缓存来存储Nokogiri对象。我在config/initializers/cache.rb中创建了这个:$cache=ActiveSupport::Cache::MemoryStore.new我想像这样存储文档:$cache.fetch(url){result=get_content(url,headers,follow_redirects)}但是我收到了这个错误:Errorduringprocessing:(TypeError)no_dump_dataisdefinedforclassNokogiri::HTML::Document/Users/d
这不是RubyequivalentofPerlData::Dumper的副本.这个问题已经超过3.5年了,因此想检查从那时起Ruby中是否有任何可用的新选项。我正在寻找perl的Dumper在ruby中的等价物。我不在乎Dumper在幕后做了什么。我已经广泛使用它在perl中打印深度嵌套的哈希和数组。到目前为止,我还没有在ruby中找到替代品(或者我可能没有找到一种方法来充分利用Ruby中的可用替代品)。这是我的perl代码及其输出:#!/usr/bin/perl-wusestrict;useData::Dumper;my$hash;$hash->{what}->{where}
我正在尝试获取一段HTML的src值。我特别尝试使用at_css而不是使用XPath来实现这一点。到目前为止,我得到的只是nil或空字符串。这是HTML:我的代码是:item=page.doc.at_css("#productMainImageimg").text.stripunlesspage.doc.at_css("#productMainImageimg").nil?putsitem#printsblankitem=item["src"]putsitem#printsblankpage.doc是NokogiriHTML元素。 最佳答案
在Ruby中,具有副作用的方法或更改作为参数传递的对象的方法带有“!”作为后缀。例如:"SomeString".gsub!(/S/,"s")将更改String对象,而"SomeString".gsub(/S/,"s")将处理String对象的副本,并且不会更改方法之外的任何对象的状态。我喜欢这个约定,我也想在用其他语言编程时使用它。我的问题:真正的Ruby程序员(我不是;-))真的使用这个约定吗?如果不是,为什么不呢?在Java、PHP、Perl、Cobol中是否有等效的命名方法约定...? 最佳答案 Bang方法并不意味着“改变接
我已经用谷歌搜索了两个小时,但找不到任何好的答案,所以让我们看看人类是否能打败谷歌计算机。我想在Ruby中解析样式表,以便我可以将这些样式应用到文档中的元素(使样式内联)。所以,我想采取类似的措施.mystyle{color:white;}并且能够将其提取到某种Nokogiri对象中。Nokogiri类“CSS::Parser”(http://nokogiri.rubyforge.org/nokogiri/Nokogiri/CSS/Parser.html)当然有一个很有前途的名字,但我找不到任何关于它是什么或它如何工作的文档,所以我不知道它是否能做什么我在这儿。我的最终目标是能够编写如
我正在使用Nokogiri进行作业,但我正在努力解决这个问题。它伤害了我的大脑。导致解决方案的任何步骤、提示或示例都很可爱。 最佳答案 这是一个简单的例子:require'rubygems'require'nokogiri'doc=Nokogiri::HTML("")doc.xpath("//meta[@name='Keywords']/@content").eachdo|attr|putsattr.valueend 关于ruby-如何使用Nokogiri获取元关键字?,我们在Stack
我正在使用Nokogiri来抓取网页。很少有url需要被猜测,当它们不存在时返回404notfound错误。有没有办法捕获这个异常?http://yoursite/page/38475#=>pagenumber38475doesn'texist我尝试了以下方法,但没有用。url="http://yoursite/page/38475"doc=Nokogiri::HTML(open(url))dobeginrescueException=>eputs"Tryagainlater"endend 最佳答案 它不起作用,因为您没有拯救在发现
我发现自己想要类似Python的东西ary=[1,2,3,4,5,6,7,8]ary[2:]#=>[3,4,5,6,7,8]这些天所有的时间。解决方案最终总是多行且丑陋。我想知道最优雅的解决方案可能是什么,因为我的不值得展示。 最佳答案 使用Array#drop2.1.0:019>ary.drop(2)=>[3,4,5,6,7,8] 关于Ruby相当于Python的"array[i:]"选择i之后的所有数组元素?,我们在StackOverflow上找到一个类似的问题:
我正在尝试在DebianLinux上安装nokogiri1.6.2.1。我正在运行Ruby-2.1.1。我已经安装了libxml2、libxml2-dev、libxslt和libxslt-dev。输出:Gem::Ext::BuildError:ERROR:Failedtobuildgemnativeextension./home/xxx/.rvm/rubies/ruby-2.1.1/bin/rubyextconf.rbBuildingnokogiriusingpackagedlibraries.checkingforiconv.h...***extconf.rbfailed***Cou